package com.gpframework.module.wages.domain.req;

import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.fasterxml.jackson.annotation.JsonFormat;
import com.gpframework.common.utils.StringUtils;
import com.gpframework.module.base.domain.req.BaseReq;
import com.gpframework.module.wages.domain.GzOfficeSalary;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.NoArgsConstructor;
import lombok.ToString;
import lombok.experimental.Accessors;

import java.util.Date;

/**
 * @ClassName GzOfficeSalaryReq
 * @Author gpframework
 * @Date 2024-01-22
 * @Version 1.0.0
 * @Description 列表查询信息体
 */
@Data
@ToString
@EqualsAndHashCode
@NoArgsConstructor
@Accessors(chain = true)
public class GzOfficeSalaryReq extends BaseReq {
    private static final long serialVersionUID = 1L;

    @ApiModelProperty("月份")
    @JsonFormat(pattern = "yyyy-MM")
    private Date month;
    @ApiModelProperty("1档口及办公室工资2中转3仓库（其他数字根据需求变化）")
    private Integer departmentType;
    @ApiModelProperty("部门")
    private String departmentName;

    /**
    * @Description 生成查询wrapper
    * @Author greatplan@qq.com
    * @Date 2020-11-04 16:04
    * @Param [lqw]
    * @Param [isVO] 是否vo查询体，true的话走的是mapper.xml里面的查询语句，不过查询语法还是mybatis-plus，主要用于某些关联查询出一些非数据表字段
    * @Return void
    */
    public void generatorQuery(QueryWrapper<GzOfficeSalary> lqw,boolean isVo) {
        String alias = "";
        if (isVo) {
            alias = "gp.";
            lqw.eq(alias+"del_status",0);
        }
        if (StringUtils.isNotBlank(this.getDepartmentName()) ){
            lqw.in(alias+"department_name" ,this.getDepartmentName().split(","));
        }

        if (this.getMonth() != null){
            lqw.eq(alias+"month" ,this.getMonth());
        }
    }
}
